package sort;

public class BubbleSort<T extends Comparable<T>> extends Sort<T> {

    @Override
    public void sort(T[] nums) {
        int N = nums.length;
        boolean isSorted = false;
        for (int i = 0; i < N - 1 && !isSorted; i++){
            isSorted = true; //一轮循环中，如果没有发生交换，则说明数组已经有序，可以直接退出。
            for (int j = N - 1; j > i; j--){
                if (less(nums[j], nums[j-1])){
                    swap(nums, j, j-1);
                    isSorted = false;
                }
            }
        }
    }
}
